﻿#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <assert.h>
#include <stdlib.h>
// 原题连接：https://leetcode.cn/problems/shu-zu-zhong-chu-xian-ci-shu-chao-guo-yi-ban-de-shu-zi-lcof/
/*
题目描述：
数组中有一个数字出现的次数超过数组长度的一半，请找出这个数字。

 

你可以假设数组是非空的，并且给定的数组总是存在多数元素。

 

示例 1:

输入: [1, 2, 3, 2, 2, 2, 5, 4, 2]
输出: 2
 

限制：

1 <= 数组长度 <= 50000

来源：力扣（LeetCode）
链接：https://leetcode.cn/problems/shu-zu-zhong-chu-xian-ci-shu-chao-guo-yi-ban-de-shu-zi-lcof
著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
*/

// 开始解题：
// 方法1——排序
int cmp_int(const void* p1, const void* p2) {
    assert(p1 && p2);
    return *(int*)p1 - *(int*)p2;
}
int majorityElement(int* nums, int numsSize) {
    assert(nums);
    int mid = numsSize / 2;
    // 先对数组进行排序
    qsort(nums, numsSize, sizeof(int), cmp_int);
    return nums[mid];
}